```
پیش گزارش آزمایش ٤
```

بردیا برائی نژاد(۹۲۱۰۱۲۲۹)

١.

```
module com(a,b,c,aBTb,bBTa,aETb);
     \ensuremath{//a} , b are 4bit numbers and c is cascade
     //aBTb means a>b,bBTa means b>a,aETb means a=b
     input [3:0] a,b;
     input [2:0] c;
     output aBTb, bBTa, aETb;
     wire [3:0] w1;
     wire [2:0] w2;
     assign w1[0] = a[0] ~^ b[0],
     w1[1] = a[1] \sim^b[1],
     w1[2] = a[2] \sim b[2],
     w1[3] = a[3] \sim b[3],
     w3 = w1[0] & w1[1] & w1[2] & w1[3],
     w2[0] = w3 \& c[0],
     w2[1] = w3 & c[1],
     w2[2] = w3 & c[2];
     assign aETb = w2[0],
     aBTb = (a[3] & ~b[3]) | (w1[3] & a[2] & ~b[2]) | (w1[3] & w1[2] & a[1] & ~b[1]) | (w1[3] & w1[2] & w1[1] & a[3] & ~b[3]) | w2[1],
     bBTa = w2[2] | (\sim (aETb|aBTb));
 endmodule
```



```
module com(a,b,c,aBTb,bBTa,aETb);
     //a , b are 4bit numbers and c is cascade
     //aBTb means a>b,bBTa means b>a,aETb means a=b
     input [3:0] a,b;
     input [2:0] c;
     output reg aBTb, bBTa, aETb;
     always @(*)
     begin
         if (a>b)
              \{aETb, aBTb, bBTa\} = 3'b010;
         else if (a<b)
              {aETb, aBTb, bBTa} = 3'b001;
         else if (a==b)
begin
              case(c)
              1: {aETb, aBTb, bBTa} = 4;
              2: {aETb, aBTb, bBTa} = 2;
              4: {aETb, aBTb, bBTa} = 1;
              endcase
         end
     end
 endmodule
```



|             |      | Value at | 0 ps | 10.0 ns | 20.0 ns | 30.0 ns | 40.0 ns  | 50.0 ns | 60. <mark>0</mark> ns | 70.0 ns |
|-------------|------|----------|------|---------|---------|---------|----------|---------|-----------------------|---------|
|             | Name | 80.0 ns  |      |         |         |         |          |         |                       |         |
| <b>№</b> 0  | a    | B 0000   | 0100 | X       | 000     | 00      | <u>)</u> | 1 X     |                       | 0000    |
| <b>→</b> 5  | b    | B 0000   | 0101 | X       | 000     | 00      | X 011    | 1 X     |                       | 0000    |
| <b>10</b>   | C    | B 000    | 000  | 001     | X 01    | 0 X     | 100      | X       |                       | 000     |
| <b>⊚</b> 14 | aBTb | A 0      |      |         |         |         |          |         |                       |         |
| 15          | aETb | A 0      |      |         |         |         |          |         |                       |         |
| <b>⊚</b> 16 | bBTa | A 0      |      |         |         |         |          |         |                       |         |

٣.

```
module com(num,a,b,c,d,e,f,g);
                     //num is the input number
                     //a,...,g are names of 7seg LED's
                     input [3:0] num;
                     output reg a,b,c,d,e,f,g;
                     always @(*)
                     begin
                         case (num)
                         0: \{a,b,c,d,e,f,g\} = 7'b1111110;//g is off
                         1: {a,b,c,d,e,f,g} = 7'b0110000;//b,c are on
                         2: \{a,b,c,d,e,f,g\} = 7'b1101101;//c,f are off
     Α
                         3: \{a,b,c,d,e,f,g\} = 7'b1111001;//f,e are off
                         4: {a,b,c,d,e,f,g} = 7'b0110011;//a,d,e are off
F
          В
                         5: {a,b,c,d,e,f,g} = 7'b1011011;//b,e are off
                         6: {a,b,c,d,e,f,g} = 7'b1011111;//b is off
     G
                         7: {a,b,c,d,e,f,g} = 7'b1110000;//a,b,c are on
                         8: \{a,b,c,d,e,f,g\} = 7'b1111111;//nothing is off
E
          C
                         9: {a,b,c,d,e,f,g} = 7'b1111011;//just e is off
                         endcase
                     end
     D
                 endmodule
```



```
module com(a,b,Cin,Cout,s);
     //a,b are numbers
     //Cin is carry in
     //Cout is carry out
     //s is sum
     input [3:0] a,b;
     input Cin;
     output reg [3:0] s;
     output reg Cout;
     reg [4:0] x;
     always @(*)
     begin
         x = a+b+Cin;
         if (x<10)
              {Cout,s}=x;
              {Cout, s}=x+6;
     end
 endmodule
```

ه.آی سی 74LS85 یک مقایسه گر ٤ بیتی است. ورودی های ٤ بیتی به A و B وارد می شوند.
 (A3) دیم MSB هستند.) ورودی های Cascading inputs برای استفاده از چند آی سی متوالی هستند تا بتوانیم اعداد بزرگتر از ٤ بیت را مقایسه کنیم.(خروجی های cascade دیگری (more-significant) متصل شوند.

